package cn.tedu.sp11.filter;

import cn.tedu.web.util.JsonResult;
import com.netflix.zuul.ZuulFilter;
import com.netflix.zuul.context.RequestContext;
import com.netflix.zuul.exception.ZuulException;
import org.apache.commons.lang.StringUtils;
import org.springframework.cloud.netflix.zuul.filters.support.FilterConstants;
import org.springframework.stereotype.Component;

import javax.servlet.http.HttpServletRequest;

@Component
public class AccessFilter extends ZuulFilter {
    //过滤器类型：pre，routes，post，error
    @Override
    public String filterType() {
        //return "pre";
        return FilterConstants.PRE_TYPE;  //配置成前置过滤器
    }
    //当前过滤器添加到哪个位置 ，返回一个顺序号
    @Override
    public int filterOrder() {
        return 6;
    }
    //针对当前请求进行判断，是否执行过滤代码（run方法）
    @Override
    public boolean shouldFilter() {
        //当前请求，调用的是否是 item-service
        //如果请求item，执行过滤代码
        //否则执行过滤代码

        //获得正在调用的服务id
        RequestContext ctx = RequestContext.getCurrentContext();//zuul请求上下文对象
        //从上下文对象获取“服务id”属性的值
        String serviceId = (String)ctx.get(FilterConstants.SERVICE_ID_KEY);
        return "item-service".equalsIgnoreCase(serviceId);
    }
    //过滤方法，权限判断写在这里
    @Override
    public Object run() throws ZuulException {

        //获得request
        RequestContext ctx = RequestContext.getCurrentContext();
        HttpServletRequest request = ctx.getRequest();

        //用request接受的token参数
        String token = request.getParameter("token");
        //如果token参数为空
        if (StringUtils.isBlank(token)){
            //阻止继续访问
            ctx.setSendZuulResponse(false);

            String json=JsonResult.err().code(JsonResult.NOT_LOGIN).msg("Not login").toString();
            ctx.setResponseStatusCode(JsonResult.NOT_LOGIN);
            ctx.setResponseBody(json);

        }

        return null;   //当前zuul版本中，这个返回值没有使用，不起任何作用
    }
}
